import router from './router'
// 引入vuex获得token
import store from './store'

// 引入进度条和样式
import nprogress from 'nprogress'
import 'nprogress/nprogress.css'
// 前置守卫
const whitelist = ['/login', '/404']
router.beforeEach(async(to, from, next) => {
  // 开启进度条
  nprogress.start()
  if (store.getters.token) {
    // 有token
    if (to.path.includes('/login')) {
      next('/') // 中转到主页
      nprogress.done()// 不会进入后置守卫所以手动关闭进度条
    } else {
      // 判断是否获取过用户资料
      if (!store.getters.userId) {
        await store.dispatch('user/getUserInFo')
      }
      next()
    }
  } else {
    // 没有token情况看是否在白名单
    if (whitelist.includes(to.path)) {
      next()
    } else {
      next('/login')
      nprogress.done()
    }
  }
})

// 后置守卫
router.afterEach(() => {
  // 关闭进度条
  nprogress.done()
})
